//
// Created by sjjmw on 3/24/2022.
//
#include "iostream"
#include "vector"
#include "list"
#include "algorithm"
#include "string"
#include "unordered_map"
#include "cmath"
#include<iomanip>
#include "string"

//int weishu(int cj){
//    int cnt=0;
//    while (cj){
//        cj/=10;
//        cnt++;
//    }
//    return cnt;
//}
int d(int n){
    int sum=n;
    while (n){
        sum+=n%10;
        n/=10;
    }
    return sum;
}
int main(){
    int a,b,c;
    while (std::cin>>a){
        std::vector<char> tag(a+1);
        for(int i=1;i<=tag.size();i++){
            int di=d(i);
            if(di<tag.size()){
                tag[d(i)]=1;
            }
        }
        for(int i=1;i<tag.size();i++){
            if(!tag[i]){
                printf("%d\n",i);
            }
            //        tag[d(i)]=1;
        }
    }
    return 0;
}